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(54) Media manager for controlling autonomous media devices within a network environment 

(57) A media manager provides data flow manage- services, physical devices and virtual devices, 
ment and other services for client applications on devic- 
es coupled together within a network. Preferably, these 
devices are coupled together within an IEEE 1394-1995 
serial bus network. A device control module is generat- 
ed for each available device for providing an abstraction 
for all of the capabilities and requirements of the device 
including the appropriate control protocol, physical con- 
nections and connection capabilities for the device. The 
media manager also manages the flow and format of 
data transfers between the devices on the network. 
Through an interface, a user accesses the media man- 
ager and enters functions which are to be completed us- 
ing the devices coupled together on the network. If the 
appropriate devices are available, the media manager 
controls and manages the completion of the requested 
task. If the appropriate devices are not available, but the 
required subdevtces are available in multiple devices, 
the media manager forms a virtual device from subde- 
vices in multiple devices in order to complete the re- 
quested task. Once the appropriate devices and subde- 
vices are assigned to a task, the media manager deter- 
mines if the data to be transmitted needs to be converted 
from one format into another format. If necessary, the 
media manager will also control the format conversion 
during the data transfer operation. The media manager 
also provides network enumeration and registry search- 
ing capabilities for client applications to find available 
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Description 

FIELD OF THE INVENTION: 

[0001 1 The present invention relates to the field of managing applications and devices within a network environment^ 
More . iarticulai, the present invention relates to the field of managing the operation of and the commun.cat.on between 
devices within a network environment. 

BACKGROUND OF THE INVENTION: 

r00O2] The IEEE 1394-1995 standard, "1394-1995 Standard ForAHigh Performance Serial Bus " is an international 
sldard for imp.ementing an inexpensive high-speed serial bus architecture which ^^^^T^^ 
isochronous format data transfers. Isochronous data transfers are real-time transfers whtch take place such ftrt the 
time intervals between significant instances have the same duration at both the transmitting and raiv.ng JP''^^ 
Each packet of data transferred isochronously is transferred in its own time penod. An example of an idea J ap p patron 
for the transfer of data isochronously would be from a video recorder to a television set. The v.deo recorder records 
mages and sounds and saves the data in discrete chunks or packets. The video recorder then transfer .each ■ packet, 
representing the image and sound recorded over a limited time period, during that time penod, for display by the 
television set The IEEE 1394-1 995 standard bus architecture provides multiple channels for isochronous data transfer 
between applications. A six bit channel number is broadcast with the data to ensure reception by the appropriate 
application. This allows multiple applications to simultaneously transmit isochronous data across he bus structure. 
Asynchronous transfers are traditional data transfer operations which take place as soon as possible and transfer on 
amount of data from a source to a destination. t i,„ r „u„ 
m003] The IEEE 1394-1995 standard provides a high-speed serial bus for interconnecting d.g.tal devices thereby 
Providing a universal I/O connection. The IEEE 1394-1995 standard defines a digital interface for the applications 
thereby eliminating the need for an application to convert digital data to analog data before it is transmitted across the 
bus Correspondingly, a receiving application will receive digital data from the bus, not analog data, and will therefore 
not be required to convert analog data to digital data. The cable required by the IEEE 1 394-1 995 standard is very thin 
in sire compared to other bulkier cables used to connect such devices. Devices can be added and removed from an 
IEEE 1 394-1 995 bus while the bus is active. If a device is so added or removed the bus will then automatically recon- 
figure itself for transmitting data between the then existing nodes. A node is considered a logical entity with a un.que 
address on the bus structure. Each node provides an identification ROM, a standardized set of control reg.sters and 

foOM] 1 ^Media debt's are being equipped with network interfaces allowing them to become part of a network such 
as the IEEE 1394-1995 serial bus network. In a home audio/video network incorporating such autonomous media 
devices it is possible that one or more such devices will be coupled together in a network with a personal computer 
settop box or other device including a microprocessor. Currently, there is a lack of available interfaces and control 
applications which will efficiently manage the interaction and operation of the autonomous devices within such a network 
configuration. What is needed is an interface which allows a controlling device within a network configuration to effi- 
ciently control communications between the devices and the operation of the devices within the network. What is further 
needed is an interface which allows a controlling device within a network configuration to maxim.ze the availability of 
devices within a network for completion of tasks and operations. 

SUMMARY OF THE INVENTION: 

[0005] A media manager provides data flow management and other services for client applications on devices cou- 
pled together within a network. Preferably, these devices are coupled together within an IEEE 1394-1995 serial bus 
network A device control module is generated for each available device for providing an abstract.on for all of the 
capabilities and requirements of the device including the appropriate control protocol, physical connections and con- 
nection capabilities for the device. The media manager also manages the flow and format of data transfers between 
the devices on the network. Through an interface, a user accesses the media manager and enters functions which are 
to be completed using the devices coupled together on the network. If the appropriate devices are available, the media 
manager controls and manages the completion of the requested task. If the appropriate devices are not available, but 
the required subdevices are available in multiple devices, the media manager forms a virtual device from subdevices 
in multiple devices in orderto complete the requested task. Once the appropriate devices and subdevices are assigned 
to a task, the media manager determines if the data to be transmitted needs to be converted from one format into 
another format. If necessary, the media manager will also control the format conversion during the data transfer oper- 
ation The media manager also provides network enumeration and registry searching capabilities for client applications 
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to find available services, physical devices and virtual devices. 
RRIEF DESCRIPTION OF THE DRAWINGS: 
5 [0006] 

Figure 1 illus.ra.es an IEEE 1394-1995 serial bus network including , video camera, a video cassette recorder, a 

F^eTn.ustrates a flow diagram of the steps involved in setting up and data transfer between two devices using 
is the media manager of the present invention. 

Figure 6 illustrates a flow diagram followed by a client application dunng startup. 

DFTAII ED DESCRIPTION OF THE PRF FERRED EMBODIMENT: 

implementing different functionaries, such as the ^"^^^^ 1394 . 1995 seria | bus network. A 

IEEE 394-1995 cable 1 6 couples the video camera 10 to the video cassette recorder 12, allowing the v.dec .camera 
10 to send data to the video cassette recorder 12 for recording. The IEEE 1394-1995 cable 18 couples the video 
assen recover 1 2 to me computer 1 4, al.owing the video cassette recorder 1 2 to -"d ^ ^e com^u er J 4 for 
« display The IEEE 1 394-1 995 cable 1 5 couples the settop box 1 3 to the computer 14. The settop box 1 3 is also coupled 

LJindude man 9 y different combinations of P^™^ "Si^^ToX^ 
i^Qd-iqq5 network are autonomous devices, meaning that in an ittb l jy« nyyo neiwulls ' ao 
so lite 1 in whSa computer is one ot the devices, there is not a true "master-slave" relationship between the computer 
and the otto devices In many IEEE 1394-1995 network configurations, a computer may not even be present. Even 
I sue cSraTons he devices within the network are fully capable of interacting with each other on a peer bas.s. 
001 21 A bSck aiaqram of a hardware system resident in the managing device for implementing the media manager 
5 Vosem SvenTnTs Istrated in Figure 2. In the hardware system iHustrated in J -JJ""^ 1 ^^ 
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28. The user interface 30 is subsystem specific, but preferably includes at least an infrared remote control device and 
a display. Alternatively, the user interface 30 also includes other I/O devices for communicating with a user of the 
subsystem. 

[0013] In the preferred embodiment of the present invention, the media manager is included within a device such as 
a television or a computer with display, in order to facilitate smooth interaction with the user. However, it should be 
apparent that the media manager of the present invention can also be implemented on any other capable device which 
includes the components necessary for providing an interface to the user. In order to implement the media manager 
of the present invention, each component in which it is implemented will include a hardware system such as the system 
illustrated in Figure 2. The CPU 22 within such a device is used to execute the application program instructions. The 
media manager of the present invention is then used to manage communications and operations within the network. 
The user accesses the media manager through the interface provided at the controlling device. Through this interface 
the user can monitor the operation and status of the network and the devices within the network. The user can also 
control the devices and request tasks to be completed through this interface. An example of these tasks include playing 
a recorded tape on the VCR 12 and displaying the output from the VCR 12 on the television 11 . The media manager 
of the present invention also manages data transfer operations and tasks requested at the individual devices. 
[0014] A block diagram of the architecture of the media manager platform of the present invention is illustrated in 
Figure 3. This architecture is divided into a so-called upper portion 32 and a lower portion 34. The lower portion 34 
preferably includes the IEEE 1394-1995 bus interface and functionality support across the most common commercial 
operating systems currently available. The upper portion 32 includes components which bring together the underlying 
IEEE 1394-1995 bus support and add in a number of features and enhancements which are provided to the client 
applications and therefore to the user. The upper portion 32 includes the block 46, which provides specific design and 
implementation for higher level IEEE 1394-1 995 bus support and the block 48, which includes and provides interfaces 
to the various client applications. The lower portion 34 includes the blocks 40, 42 and 44 which provide support for the 
most common operating systems, including Windows 95®, Macintosh® and Aperios™ operating systems, respectively. 
Support for any general operating system, such as OS9, is also provided. The lower portion 34 also includes the block 
38, which provides the common layer of I EEE 1 394-1 995 support, and the blocks 36 which provide the actual physical 
IEEE 1394-1995 bus interfaces to other devices coupled to the controlling device. 

[0015] The media manager platform provides an open and flexible architecture in order to efficiently integrate per- 
sona! computers and other autonomous devices into a network configuration and effectively manage the necessary 
data transfer operations between those devices. The lower portion 34 of the architecture has been designed to support 
the underlying technology at the lowest levels, which allows the higher levels to support more general modules and 
functional descriptions. 

[0016] A more detailed block diagram of the architecture of the media manager platform of the present invention is 
illustrated in Figure 4. The multimedia or user-level application 48 sits at the top of the architecture and makes use of 
the services provided by the media manager. The multimedia application 48 is an application or other client of the 
media manager platform of the present invention. The architectural components within the media manager manage 
the protocol specifics and export a simpler programming interface up to the application 48. Issues such as timing, buffer 
management, bus management and communication protocol are hidden behind these simple functional interfaces. 
The application 48 also has access to the lower layers of the architecture and will of course be able to communicate 
directly with the hardware adaptation layer (HAL) and the host operating system 58. The host operating system is 
coupled to the other devices within the network, such as the camera 10, the VCR 12 and the settop box 13. For 
illustration purposes, in this configuration the media manager of the present invention is implemented on the computer 
system 14 of Figure 1. 

[0017] The application interface object 50 serves as a proxy for the client application 48 within the media manager 
environment. An applications programming interface is provided to allow the client applications 48 to access the basic 
services of the media manager. Access to more detailed or specific functionality provided by certain programming 
interfaces is also provided through the application interface object 50 which provides the application 48 access to the 
local messenger 52. 

[0018] The local messenger 52 is one component of the messaging system integrated into the media manager. 
Preferably, this messaging system is the AV Messenger system. The local messenger 52 is the central hub of com- 
munications between all objects on a given node, when those objects exist in separate execution spaces. Essentially, 
the local messenger 52 is the inter-application communication model which is provided by tho host operating system 
58. The local messenger 52 is the bottleneck through which all messages between software modules pass. To achieve 
scriptability. the local messenger 52 logs all messages as they pass through, keeping an internal database of all mes- 
sages and their relevant data including address of destination, parameters, address of response and optionally, a time 
stamp for time-based scripting. 

[0019] The service registry 59 includes a reference to all addressable entities within the media manager 71. This 
registry includes a reference for each device control module (DCM) 56, the DCM Manager 54, the data flow manager 
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64 the transaction manager 66, the data format manager 68, the bus manager 70 and the graphics manager 72. The 
service registry 59 also contains any number of service modules 60, as will be described below. The service registry 
59 also contains a service registry database including references for all of the objects that are local to its node and at 
specific times references to remote objects as well. Each entry in the database refers to an addressable module and 

5 includes attached attributes, some of which are common to all entries and others which are specific to a type of module. 
Common attributes include such things as the module name and the local ID. Module-specific attributes will vary by 
the type of module. Once the entry exists in the service registry database, any number of attributes can be added to 
an entry. When a client application searches the database, the application specifies a set of attributes to match and 
the service registry 59 searches the database, finding and returning all entries which match the specified criteria. If 

10 multiple candidates are found during this search, the service registry 59 will provide a list reference to the client appli- 
cation 48. The client application can then examine each of the candidate items in the list, to determine the items of 
interest. 

[0020] A client application 48 may have multiple outstanding search lists, each representing the results of a different 
search criteria. When the client application 48 needs to update a search list, in response to an event such as a bus 
is reset in which different devices may be available, the application 48 passes the list reference back to the service registry 

59 when making a search call. This allows the service registry 59 to update the existing list object, rather than disposing 
of it and reallocating a new one. 

[0021 ] The service modules 60 are modules which can be called to perform some set of services. The service modules 

60 perform a variety of services for client applications, including such services as data format, transport and control 
20 protocol translation. 

[0022] The DCM manager 54 is responsible for handling the group of DCMs 56 on its local node or for the devices 
within the controlling device's network. These responsibilities include the tasks of discovering, instantiating and dis- 
posing of all possible DCM candidates that are available to a given system. In addition, the DCM manager 54 commu- 
nicates with other DCM managers on remote nodes, if any : to arbitrate for network-wide device and subdevice resource 

25 allocation and management. 

[0023] The DCM manager 54 works with the underlying operating system services to get a raw list of available device 
node handles. The DCM manager 54 also provides an application programming interface for the client application 48 
to discover what subdevices, represented by DCMs 56, or other services are available within the devices on the network. 
A DCM 56 represents a device or subdevice available for allocation by the DCM manager 54. A DCM 56 can represent 

30 a physical device or a virtual device formed of subparts from different physical devices. The other available services 
are represented by virtual DCMs 56, which will be discussed below. The available DCMs will be dynamic, depending 
on the available physical devices on the IEEE 1394-1995 serial bus. 

[0024] For each node, the DCM manager 54 does enough work to determine that it should create a DCM 56. This 
is done for all media-related devices which will be managed under the umbrella of the media manager of the present 
35 invention. For each media-related entity, the DCM manager 54 creates a generic DCM 56. Each DCM 56 then has the 
responsibility to make itself more device-specific, as will be described below. 

[0025] Device-specific DCMs provided from manufacturers can also be added into the DCMs 56. Device-specific 
DCMs can come from a variety of sources including an embedded read-only memory (ROM) within the device or some 
other storage mechanism such as the header of a disc or tape. The device-specific DCM may also be downloaded 
40 from an internet site or via a direct modem connection, if such capabilities are accessible to the media manager, or 
supplied from a disk or other storage medium. 

[0026] The DCM manager 54 is responsible for adding and disposing DCMs 56 at the appropriate times, and notifying 
clients that DCMs 56 have been added or removed. The DCM manager 54 is also responsible for coordinating complex 
services among multiple DCMs 56. These complex services, such as command queuing of complex operations, require 

45 the DCM manager 54 to coordinate with multiple DCMs 56 to carry out these operations. 

[0027] The DCMs 56 each provide a device modeling and control protocol abstraction service by exporting a stand- 
ardized interface for device control up to the client application 48. The programming interface for device control provided 
by the DCMs 56 is divided into common AA/ control and device-specific A/V control. The common A/V control com- 
mands are common to virtually all devices having audio-visual capabilities. The basic transport control functionality 

so such as Play, Stop, Fast Forward and Rewind commands are included here. The device-specific AA/ control commands 
include features common to a given category of AA/ devices, such as the Record command for devices with recording 
capability, and features that are specific to a certain model or group of devices. The information for device-specific 
functionality can either be built into a device-specific DCM which is embedded in the device itself, using the self- 
describing data structures mentioned previously, or it can be downloaded as a software upgrade from the internet. 

55 [0028] The media manager of the present invention employs protocol abstraction which means that the programming 
interface between the modules and the application is the same, regardless of the kind of device and the controlling 
protocol being used. Accordingly, the application will use the same source code and message to cause an IEEE 
1 394-1 995 VCR to record as it would use to cause a Video System Control Architecture (VISCA) VCR to record. This 
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is true for the common A/V control commands and the category-specific control commands; features that are truly 
specific to a particular device will have a unique programming interface. 

[0029] The DCM 56 is the mechanism by which self-describing data from a device is downloaded and presented to 
the user. This requires the DCM 56 to analyze the self-describing information, by downloading and integrating modules 
and managing the presentation of this information to the user through a host application. This allows a user to configure 
and control both the well-known and device-specific functionality of devices on the network through the media manager 
interface. 

[0030] Together, the DCM manager 54 and the DCMs 56 perform command queuing of AV commands to be executed, 
allowing the DCM 56 to deal with all device peculiarities, such as the need to perform a pre- roll to accountfor mechanical 
latency of a device. The DCM manager 54 and the DCMs 56 in coordination with other parts of the media manager 
also provide the ability to specify device control actions that are taken at specific times and as the result of certain 
conditions. 

[0031] The DCMs 56 make up a large part of the overall architecture of the media manager of the present invention. 
The DCM 56 provides an abstraction for all of the various pieces of technology that make up an audio-visual device, 
such as the control protocol physical connections and connection capabilities. A DCM 56 can also be created which 
does not represent a physical device, but represents a virtual device comprising a collection of functions or services 
that carry out a particular AV operation. 

[0032] Physical devices and subdevices are individually accessible pieces of hardware. The media manager of the 
present invention uses accessible subdevices to support virtual devices to add enhanced capability to a network of 
devices. The virtual devices are logical entities which are combined from pieces of a variety of available components 
Preferably, the virtual devices are created automatically when necessary to complete a requested task. Alternatively, 
the virtual devices are created dynamically by requesting the service from the DCM manager 54. 
[0033] An AV action is a pre-defined action or activity such as "watch television" or "record a movie," or any set of 
user-defined actions involving the manipulation of devices by using the DCMs 56. The actions can be recorded for 
later re-use by a user. An AV action applications pro grarrning interface is a way of modeling common actions that are 
performed with devices in an AV network, such as viewing a recorded show, viewing a broadcast show, duplicating a 
tape and listening to a compact disk. For example, if a VCR is located in an upstairs bedroom within a user's house 
and is currently receiving a broadcast through the tuner and displaying it on a television in the bedroom, the transport 
mechanism within the VCR is not being used. If the user then desires to view a recorded show on the television down- 
stairs, the media manager of the present invention will allow the user to place the video tape in the transport of the 
VCR in the bedroom and watch the recorded show from the tape on the downstairs television. The data representing 
the recorded show is transmitted from the upstairs VCR over the IEEE 1 394-1 995 serial bus network to the downstairs 
television. This data transfer operation is controlled by the media manager in the controlling device. Similar functions 
and virtual devices are achieved with tuners, demuxers, transports, amplifiers, processors and other components and 
subdevices. Accordingly the user can maximize the functionality and capability of the devices within the network using 
the media manager to control their operation. 

[0034] The DCM manager 54 keeps track not only of what physical devices and subdevices are being used, but also 
what virtual devices can be created from components and subcomponents that are currently available. The DCM 
manager 54 does this for all of its locally managed devices and for software services available on the host platform on 
which it is executing. The DCM manager 54 also provides the programming interfaces for a client application 48 to 
inquire about the virtual devices that can be created based on the resources available on the network, as well as what 
AV actions can be currently performed. The DCM manager 54 also ensures that virtual devices get added to the service 
registry 59 at the appropriate times. 

[0035] The applications programming interface provided for the DCMs 56 is designed to allow the client applications 
48 to discover what features and capabilities are available within the devices in the network and then work with those 
devices as necessary. This programming interface includes device control, device management, connection manage- 
ment and management of the self-describing device implementation. Each of the DCMs 56 have the responsibility to 
convert from a generic DCM to a device or protocol specific DCM by determining the type of device it is managing. 
This requires that the DCM examine the self-describing device data from the device, if any is present, and analyze any 
other information that may be available. The DCMs 56 also have the responsibility to provide access to the self-de- 
scribing device information data for the device being managed, including the device image, a product name string and 
functional descriptors to other devices and components. The DCM 56 is further responsible for providing a consistent 
interface for device control, including the complex services such as command queuing. Carrying out these commands 
requires coordination with the host operating system 58 for device control protocol usage, including packaging, sending, 
processing protocol-specific commands and responses via the protocol driver and other operating system provided 
support mechanisms. 

[0036] Each DCM 56 also monitors the device it is controlling and provides extended notification support to the 
necessary components and applications. All normal events generated by the device go through the DCM 56 for the 
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appropriate device, to the event manager 62 and to all interested client applications 48. In addition to supporting the 
AV/C device notification events, many situations may not be supported explicitly in either the AV/C protocol, in a given 
device or other control protocol. Depending on the capabilities of the device and its control and communications pro- 
tocols, it is possible to provide extended support for such events which do not trigger actual event messages The DCM 

5 56 watches the device for this kind of activity and posts an event to the event manager 62. 

[0037] Each DCM 56 is also responsible for managing themselves in terms of the outside entities which are making 
use of the data from the device under their control and the entities that are controlling them. This includes support for 
resource sharing and resource queuing. Resource queuing allows an entity to reserve a busy DCM for its use, as soon 
as the DCM 56 is available. As soon as the DCM 56 is available, it will then notify the entity. 

w [0038] The DCMs 56 also preferably maintain a presence during environmental changes allowing the DCM and 
cheats to support both on-line and off-line states. This allows the DCMs 56 to quickly re-establish the services of a 
device once it comes on-line again. 

[0039] Within the media manager of the present invention, the DCMs 56 are responsible for controlling the available 
devices and subdevices. The DCMs 56 provide access to the capabilities of the device, both general and device- 
's specific. In an alternate embodiment of the present invention, each device, as part of the self-describing data : has an 
embedded DCM, ensuring that the software is always available regardless of where the device is taken. In a further 
alternate embodiment, the DCM for a specific device is obtained from the device manufacturer or a third parry over 
the internet or provided on a media device, such as a floppy disk. In each of the above embodiments, the DCM 56, 
once downloaded can be stored in a variety of locations. Preferably, the DCM 56 is stored on the device it controls. 
20 However, the DCM 56 can also be stored in any appropriate location. In an alternate embodiment of the present in- 
vention, the DCM 56 is written in common byte or script code format such as Java or Java Script, supported by the 
host platform. The DCM 56 is then uploaded to the host device and executed there. 

[0040] The event manager 62 broadcasts all event notifications within the network to all interested parties. The event 
manager 62 acts as a central location for all modules within its node to register for notification when events occur in 

25 that node. The event manager 62 maintains an event notification list data structure which is a list of the defined event 
types and the destination identifiers of all devices which have registered for notification of each type of event. The 
devices each register with the event manager 62 for each event type that is of interest to them, providing their client 
identifier and a token value to be passed back to them when the event message is broadcast. An event is an actual 
occurrence of some action and a message from a device which is addressed to multiple destinations. 

30 [0041] The event manager 62 does not usually generate events, but accepts and broadcasts events posted by other 
components with the media manager. When broadcasting events to client applications 48 in remote nodes, the event 
manager 62 makes use of the broadcast manager 74. The event manager 62 handles the interaction with the user and 
informs the appropriate devices accordingly. The event manager 62 informs the DCMs 56 of what user input is occurring 
through the interface at the control software level, so that the DCMs 56 can handle their physical devices appropriately. 

35 A DCM 56 controlling its device from a remote location will need to receive messages indicating what the user is doing 
and will need to send appropriate messages to its device. The event manager 62 supports the execution of remote 
DCMs 56 by means of the messaging system and well-defined event messages. The well-defined event messages 
include device administration, such as a new_device message generated when a device is added to the network : and 
user interaction . In addition to well-defined event messages, any two DCMs or software modules can also define custom 

40 or private messages. 

[0042] The graphics manager 72 manages the embedding of remote device controls into a controlling application 
and supports the remote presentation of self-describing data information by the DCMs 56. The graphics manager 72 
provides a programming interface that allows the DCMs 56 to arbitrate for screen space and to work within a shared 
graphics environment. This allows the specific capabilities of a device to be presented to and accessed by the user 

45 through the interface of the controlling software. 

[0043] The data format manager 68 manages the format of the data flowing between devices. This includes the 
ability to plug into the resident media manager for data format conversion as part of the buffer management and data 
format process. Most of the data format conversions are done transparently on behalf of the client application, based 
on knowledge of the source and destination of the data. Other data transformations require the client application 48 

so to set up a format conversion process. Preferably, the format conversion is performed in-line while the data is being 
transmitted. Alternatively, the format conversion is performed as either a pre or post processing task to transmission 
of the data. The data format conversion services available on a given platform are stored in the service registry 59. In 
addition to using the registry to find services ! the data format manager 68 is responsible for instantiating the service 
modules and registering them with the service registry 59. 

55 [0044] The data flow manager 64 works with the bus manager 70 to provide services to assist with routing data from 
source to destination, which may include many nodes in between. In the event that the source and destination device 
involve different data types, or are separated by a barrier, the data flow manager 64 will work with the data format 
manager 68 and the service registry 59 to handle automatic or requested data translation services as well. During the 



7 



EP 1 217 787 A2 



transfer of isochronous data, the data flow manager 64 provides buffer allocation and management services. Buffer 
management includes the provision for a consistent notification mechanism to inform the client application when data 
is available for processing. While isochronous data is flowing into the client application 48, various memory buffers are 
filled with the data. The data flow manager 64 informs the client application 48 when each buffer is filled so that it can 
handle tie data acquisition process from the buffer. In addition, buffer management is simplified for client applications 
by having the appropriate service modules partition memory in a manner that is optimized for the data being captured. 
This includes separating the allocated memory into scan line or frame-sized segments for a stream of video data or 
the optimum segment sizes for raw audio and MIDI data. 

[0045] A flow diagram of the steps involved in setting up a data transfer between two devices using the media man- 
ager of the present invention is illustrated in Figure 5. The method starts at the block 100. When a client application 
48 desires to establish a connection between two devices for a transfer of data, the application calls the EstablishEx- 
ternalConnection() method of one of the two DCMs 56 that represent the two devices and passes the modulelD value 
of the other device's DCM 56 as a parameter (Block 1 02) The DCM 56 that was called then calls the data flow manager 
64 to assist with making the connection and passes both the source and destination DCM module IDs as parameters. 
(Block 104) The data flow manager 64 then analyzes the source and destination IDs to determine that they are in 
different nodes. (Block 106) The data flow manager 64 next obtains the topology map of the network from the bus 
manager 7 of the source node. (Block 108) The data flow manager 64 then analyzes the topology map to find the 
destination node and determine if it is on the topology map. (Block 11 0) If the destination node is on the topology map : 
then the data flow manager 64 jumps to the Block 1 1 8 to determine the best route for the data transfer. If the destination 
node is not on the topology map, then the data flow manager 64 obtains the destination DCM from the service registry 
59 in order to determine the transmission protocol for that node. (Block 112) The data flow manager 64 then finds the 
appropriate transmission protocol service module and sets up the appropriate conversion process. (Block 114) It is 
then determined if multiple transports need to be bridged. (Block 116) If multiple transports do need to be bridged then 
the data flow manager 64 jumps back to the Block 114 and obtains another transport conversion module. Otherwise, 
the data flow manager 64 then analyzes the connection paths to determine the best route for the data flow. (Block 1 1 8) 
The data flow manager 64 then analyzes the input data formats for the source and the destination nodes in order to 
determine if a conversion is necessary. (Block 120) It a conversion is necessary, the data flow manager 64 obtains the 
appropriate format converter from the service registry 59, based on the input and output format and sets up the con- 
version process. (Block 122) Otherwise, the data flow route is complete and the data transfer between the two devices 
can begin. (Block 124) 

[0046] The bus manager 70 abstracts the underlying device interconnection mechanism, providing a common set 
of programming interfaces to describe the capabilities of the bus architecture. In the preferred embodiment of the 
present invention, the devices are connected by an IEEE 1394-1995 serial bus. For the IEEE 1394-1995 serial bus 
network, the bus manager 70 resides on the top of the I EEE 1 394-1 995 HAL layer that is provided by the host operating 
system 58. The bus manager 70 then helps to generalize the bus management activities up to the media manager of 
the present invention. The bus manager 70 notifies the client applications 48 when bus reset activity occurs by send 
mg out bus reset notifications through the event manager 62 and providing complete information about how the envi- 
ronment has changed. The client applications receiving this information are provided with information about the devices 
which may have suddenly disappeared and the devices which have suddenly become available after the bus reset. 
[0047] The bus manager 70 also provides topology maps, speed maps and other environment descriptions to client 
applications 48. Information from the topology map is used to build a user interface that helps the user understand the 
connection of the devices and how certain features may be used. This information is also used to provide automatic 
data routing as described above in relation to the data flow manager 64. The speed map is used to analyze the current 
connection scheme and to give the user helpful suggestions for improving the performance of devices on the network 
by rearranging the way that devices are connected. The bus manager 70 also provides atomic-level data communica- 
tions services for two nodes or software modules within the nodes, to send bytes to each other in a preferred format 
or protocol. This protocol is built on top of those atomic communications functions. 

[0048] After a bus reset or change notification of the bus, the bus manager 70 assigns new ID values to all devices 
which have just appeared and determines what devices have disappeared. The bus manager 70 then invokes the DCM 
manager 54 to create new DCMs 56 for the devices which have just appealed and posts a bus change notification to 
the event manager 62, which will notify all registered clients about the bus reset. This notification provides enough 
information for the client applications 48 to determine what devices have changed on the bus. 

[0049] The transport adaptation modules 78 take care of packaging message data before it is passed on to the HAL 
for actual transmission to the destination device. The HAL is at the lowest layer of the media manager of the present 
invention. This layer provides a common programming interface upward to clients such as the DCMs 56 and any other 
entities that need to communicate with it. The transport adaptation modules 78 use the atomic messaging functions 
of the bus manager 70, as described above. 

[0050] As described above, the DCMs 56 provide a protocol abstraction service, by exporting a standardized interface 
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for device control up to the multimedia application 48. The programming interface provided by these ~™P on f"*« ' 8 
divided into a common audio/video control level and a device-specific control level. The common aud,o/v dec control 
level provides an interface for common commands, including the basic transport control functional** such as Pta* 
Stop Fast-Foiward and Rewind commands. The device-specific control level provides an interface for dera-epeci te 

s commands, including features common to a given category of devices, such as Record for «^°«^™^J2 
capability, and features which are specific to a certain device or group of devices. The protocol ab «^ 
provided by the DCMs 56 ensures that the programming interface between the modules and the application 48 is 
always the same, regardless of the kind of device and the controlling protocol being used. This feature allows a great 
degree of flexibility for the application and the user. The DCMs 56 also provide a user input event abstraction model 

w so that client applications can display graphical user interface elements and send standard user event messages to 
the DCM 56 as the user interacts with the graphical user interface elements. 

rO051l The media manager of the present invention provides data flow management and other serv.ces. The media 
manager acts as an extension of the hosting operation system 58 and provides a variety of serv.ces to the other 
components of the media manager platform as well as to the client application 48. The media manager manages and 
»5 organizes the DCMs 56. The media manager discovers and initializes the DCMs 56 which are appropriate for the 
a ^cations present, while disposing of the unnecessary DCMs 56. The media ™^ tol1 ^ - ^''gJS 
each time the system is booted, or any time the system could possibly change, such as when the IEEE 1 394-1 995 bus 
fs reselVhe media manager also provides a wrapper around the particular dynamically linked library so.ut.on tha ,s 
used on the host operating system 58. This allows the best dynamically linked library to be used to implement modules 
20 on a given operating system, while still maintaining a consistent interface to outside applications. 

[0052] The media manager is also responsible for managing the flow and format of data transfer operations between 
the devices on the network. When managing the flow of data, the media manager will allocate and manage the appro- 
priate buffers in a fashion independent of the operating system being used. „ . _ 
[0053] The media manager also provides high-level protocol management of the IEEE 1394-1995 bus environment. 
In order to fully support dynamic device actions such as hot plugging up to the user level, the applications and devices 
need to be aware of changes to the IEEE 1394-1995 bus environment. The media manager through the bus manager 
70 and the event manager 62 is responsible for informing the applications and devices that bus reset activity has 
occurred on the IEEE 1394-1995 bus, by sending out bus reset notifications and providing complete information about 
how the environment has changed. The media manager also provides topology maps and other environment descrip- 
tions to the applications and devices also through the bus manager 70. The topology map illustrates the connections 
between devices within the IEEE 1394-1995 network. Information derived from the topology map is used to build a 
human interface which helps the user u nderstand how the devices are connected and how certain features may be used 
[0054] The application service modules 60 provide a level of services between the host operating system 58 and 
the application 48 in order to provide basic functionality for the application 48 independent of the specific operating 
system being used. This functionality includes providing memory allocation and disposal routines which are more robust 
than the basic functions available in most operating systems and providing device configuration and contro modules 
which are self-contained, stand-alone modules for providing all user interface and interaction management when in- 
vokGd 

[0055] The transport adaptation modules 78 provide a common programming interface to the device control modules 
50 and to the application 48, taking care of bringing the protocol capabilities up through the host operating system 58 
The internal design and implementation of the system level interface block 50 takes advantage of the spec. ,c host 
operating system architecture being used in order to realize the IEEE 1 394-1 995 functions available to the application 

48 . . 

[0056] The media manager platform of the present invention includes the DCMs 56, the application service modules 
45 60 and the system level interface for IEEE 1 394-1 995 bus protocol provided by the transport adaptation modules 78^ 
During normal operation, the application 48 will communicate with all of these components. When communicating with 
the DCMs 56, the application 48 will use a single programming interface. When communicating with the application 
service modules 60, the application will also use a single programming interface. 

[0057] A client application 48, as described above and illustrated in Figures 3 and 4, is an entity which resides above 
so all the other components in terms of the architecture of the media manager platform of the present invention. For the 
completion of a majority of its required tasks, the application 48 will communicate with the DCMs 56 and the application 
service modules 60 which are present via the local messenger. For the times when it is necessary, the application 48 
has access to the lower levels of the architecture through the host operating system 58. 

[0058] Upon startup of the client application 48, the client application 48 must initialize and register w.th the med.a 
55 manager The client application 48 initializes the media manager in order to make sure that the media manager is up 
and running and ready to serve the application 48. The client application 48 registers with the media manager in order 
to give the media manager all of the necessary information for interaction with the application 48 and to register itself 
with the messaging system. When starting up, generally an application 48 must make sure that the host operating 
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system has been initialized, that a minimum level of services are available and that it has the necessary amount of 
memory available to run. These steps are performed for the application by the media manager after the application 48 
initializes the media manager. 

[0059] When starting up. a client application 48 follows the steps illustrated in the flow chart of Figure 6. The appli- 
5 cation 48 starts up at the step 140. After starting up, the application 48 initializes the media manager. In the preferred 
embodiment of the present invention the application initializes the media manager by making the following call: 
err = SMMJnitialize 

When initialized, the media manager will allocate the necessary memory and system services to support the application 
48. 

10 [0060] After initialization of the media manager is complete, the application 48 then registers with the media manager 
at the step 1 44. This step of registering allows the application 48 to provide the media manager with specific information 
that the media manager will need in order to properly support the application 48. For example, the application 48 must 
provide the address of a callback routine for notification of significant events related to the environment including IEEE 
1394-1995 bus resets, asynchronous transaction completion and triggers when memory buffers have been filled with 

15 a specified amount of isochronous data. The step of registering is completed by the following instruction: 

SonyErrorResultType SMM_RegisterClient (SMMCIientldentifierType* the ClientID, 
SMMBusEventNotificationUPP clientBusEventNotificationCallback, void* clientBusEventCallbackData); 

20 [0061] The parameter theClientID is a unique identifier created by the media manager for the application. In future 
communication with the media manager, the application 48 will be required to pass this identifier back in, such as when 
it is closing down and unregistering with the media manager. The parameter clientBusEventNotificationCallback is an 
appropriately formatted reference to the callback function that the application 48 will implement. The application 48 is 
not required to implement such a callback function if the application 48 does not need to know about dynamic changes 

25 which may occur to the network environment If the application 48 does not implement this callback function, then the 
application will pass a NIL value for this parameter. 

[0062] The parameter clientBusEventCallbackData can be any value that the application 48 will require access to in 
the callback routine. Normally, this value will be a pointer to a block of memory such that when the media manager 
invokes the callback function, it will pass this value back to the client application 48, allowing the application 48 to then 

30 access global storage or other appropriate data. 

[0063] To complete the step of registering with the media manager, the application 48 must also implement the 
notification callback function using the following interface: 

pascal void (*SMMBusEventNotificationProcPtr)(void *clientData, SMMBusEventType busEventlndicator, SMM- 
BusEventRecPtr busEventlnfo); 

35 [0064] The parameter clientData is the clientBusEventCallbackData parameter that was passed in to the registration 
function. The parameter busEventlndicator is an enumerated data type which indicates what kind of event the appli- 
cation is being notified of. The specified events include a bus reset, when a device is plugged into or unplugged from 
the network, the completion of an asynchronous transaction and when a specified buffer is full during an isochronous 
transfer of data. The parameter busEventlnfo provides a data structure that contains relevant information for the par- 

40 ticular event. 

[0065] Aftercompleting the step of registering with the media manager, the application 48 then will obtain the available 
DCMs 56 at the step 146. By obtaining the available DCMs 56, the application 48 will know the other types of devices 
which are coupled within the network. This step is composed of a series of sub-steps. An iterative callback model is 
used as the method of data transfer for transferring the data to the application 48. The client application 48 first gives 

45 the media manager an address of a callback function The application 48 then enters a loop and repeatedly requests 
information about the next module from the media manager until there are no remaining DCMs. The media manager 
prepares a data structure with the necessary information and transfers it to the application 48 via the callback function. 
Once the information about each specific DCM 56 is received, the application 48 then copies the information which it 
requires. This process is repeated until all of the available DCMs 56 have been received by the application 48. Within 

50 an alternate embodiment of the present invention, the client application queries the system registry, requesting a handle 
to each of the available DCMs 56. 

[0066] The preferred callback function which the application 48 must implement to obtain the available DCMs 56 is 
defined as follows: 

void DevicelnfoCallbackRoutine(void *userData t SMMDevicelndexType devicelndex, SonyAvDeviceRecPtr de- 
55 vicelnfo) 

The parameter userData of the callback function is the means of transferring data between the media manager and 
the application 48, The application 48 will define its own data structure, allocate the memory for one of these structures 
and pass the address of that structure to the media manager. That address is then passed back in this callback function 
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allowing the application 48 to access that data structure for the purpose of copying information into it. 
[0067] The parameter devicelndex of the callback function is the index value of the loop which the application 48 
enters to obtain information about the available DCMs 56. The loop is bounded by the number of available DCMs 56. 
This parameter is passed back to the application 48 in the callback function so that the application 48 can save this 
parameter along with the other information passed into the callback function. This index value is useful m other calls 
to the media manager by the application 48, when inquiring about a specific DCM 56. In addition, this index value will 
be used when notifying the application 48 that a device has disappeared after it was unplugged or disconnected from 
the network. The application 48 will store this index value for each DCM 56 within a dedicated field in its private data 
structure. 

[00681 The parameter devicelnfo of the callback function is a pointer to a data structure labeled SonyAVDeviceRec, 
in which the media manager stores the DCMs 56 for retrieval by the application 48. The format of this data structure 
is known to both the application 48 and the media manager. Once a DCM 56 is stored within this data structure, the 
application 48 will then copy the appropriate information from the data structure to its own private data structure. The 
data structure SonyAvDeviceRec is defined in Table I below: 

TABLE I 



typedef struct SonyAVDeviceRec 


unsigned long 


devicelD; 


//SMM Device IDType? 


unsigned long 


busGeneration; 




SONY_DeviceModuleRefType 


controlModuleReference; 




unsigned long 


reservedl ; 




unsigned long 


reserved2; 




SonyAVDeviceRec, *SonyAVDeviceRecPtr, "SonyAVUeviceHecnai; 



[0069] The parameter devicelD is the identifier of a DCM 56 and correspondingly of a device. This identifier is used 
by the application 48 whenever it wants to communicate with a DCM 56 or when the application 48 requests services 
from the media manager regarding a specific device. 

[0070] The parameter busGeneration is a value which changes after each bus reset action. After each bus reset, 
when devices are added or removed, certain information about the bus and the connected devices will change. Each 
time that the IEEE 1394-1995 bus is reset, the value of the parameter busGeneration is updated. 
[0071] The parameter controlModuleReference is a reference to the DCM 56 that is associated with the specified 
device. This reference is used when the application 48 requires the modia manager to act on its behalf in transactions 
with the module. 

[0072] The application 48 will next request that the media manager generate a list of available DCMs 56 and the 
number of modules within that list using the following function call: 

SonyErrorResultType SMM_FindDeviceControlModules (SMMDeviceListRefType* theDeviceList, unsigned long 
deviceAttributes, short* numAVDevices) 

The parameter theDeviceList includes the address where the list of available DCMs 56 is stored and is generated and 
returned by the media manager. The application will declare a local variable of this type and pass the address of that 
variable to this function. 

[0073] The parameter deviceAttributes includes a set of bitwise flags which the application 48 uses to specify the 
types of DCMs 56 which should be returned. For example, the application 48 may only wish to know about the active 
devices connected to the network. When certain flag values are specified the media manager will filter the list for only 
the devices meeting the criteria, before the list is returned to the application 48. The application 48 can specify that 
the list include all identifiable devices, only devices that are up and running, only devices that are plugged in but have 
their power switch turned off or only snoozing devices. 

[0074] The parameter numAVDevices includes the number of DCMs 56 in the list that is returned to the application 
48. The application 48 uses this number as the upper boundary of the iteration loop to obtain the DCMs 56. 
[0075] The application 48 prepares the callback function address and then enters a loop to repeatedly call the media 
manager until the information on all of the DCMs 56 within the list is obtained. On each pass through the loop, the 
application 48 makes one call to the following function: 

pascal SonyErrorResultType SMM_GetDeviceControlModulelnfo (SMMDeviceListRefType theDeviceList, SM- 
MDeviceindexType whichDevice, unsigned long reserved, SMMDeviceControlModulelteratorUPP theDeviceListCall- 
backFunction, void *userData) 

The parameter theDeviceList is the list reference that was returned from the function call FindAIIDeviceControlModules 
(). The parameter whichDevice specifies which of the DCMs 56 that the application 48 is requesting information about. 
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The parameter theDeviceListCallbackFunction includes the prepared callback function address. The parameter user- 
Data is a reference to an application-defined data structure. This reference is passed back to the application 48 in the 
callback routine and the application 48 will then transfer any needed information from the media manager to this data 
structure. 

[0076] The entire preferred sequence of the step to obtain the available DCMs 56 is listed in Table II below: 



TABLE E 



SMMDeviceListRefType theDe vice List « NULL; 

if (nil ! = theDeviceList) 

err * SN/fltf_FmdAHDcrviceCoDtro^ kActjveDevices + kXnactiveDevice*:, 

&gK umA VDc vices); 

if (noErr = err) 

{ 

gAVDeviceList = NewHandle(0); 

//Prepare die callback function for the media manager 
tfaeDeviccInfoCallbaclc « NewSMMDeviceCoatrolMod^ 
if ( (ail !- theDeviceJufcCallback) <fc<£: (nil != gAVDeviceList) ) 

for(kiop « 0; loop < gNumAVDc vices; loop-H-) 
{ 

err = SMM_GeiDevicbControlModuleInfo (theDeviceList, loop, 0, 

theDevicelnfoCallback, gAVDeviceList); 

Di^05eRoutineDcimptor(theDeviccIiLfoCiUbac3c); 

} 

else 

err = -1; 

} 

void DevicelcfoCaUbackRoutine (void *usedDaTa, SMMDcvicelndexType devicelndex, 

SonyAVDeviceRJBCPtr 

devicctofo) 

< 

//Copy any information that I care about from the deviceEnfo data structure 
A'avcr to my private data referenced by UscrDnta: 

(myPrivateRecord?tr) xiserDatar^tkrviccID - deviceInfo->deviceID; 



[0077] After the available DCMs 56 are obtained by the application 48, the application 48 will then obtain device 
specific information at the step 68, The DCM information returned by the media manager is system level information 
which includes the unique identifier for each device and protocol-specific information such as the bus generation for 
the IEEE 1394-1995 devices. In order to obtain the device specific information such as status, descriptive name string 
and an image of the device, the application 48 must communicate with the device through the appropriate DCM 56. 
By completing the steps illustrated in Figure 6 and described above, the application 48 will have completed its startup 
routine and is now ready for operation. 

[0078] While the application 48 is operating it will be handling user and system level events and messages including 
receiving control inputs, as well as messages from other processes, the host operating system and the media manager. 
[0079] It will be apparent to those skilled in the art that while the preferred embodiment of the present invention is 
used to manage devices coupled together within an IEEE 1394-1995 serial bus structure, the present invention can 
also be implemented to manage devices within other bus structures. 
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Claims 

1 . A method of managing operation of and communication between a network of devices comprising the steps of: 

5 a) maintaining a control module (56) for each device in the network, wherein the control module (56) includes 

the capabilities of the device and any subdevices within the device and further wherein the control module 
(56) is responsible for control of the device; 

b) providing an interface (30) to a user through which a task to be completed is requested by the user; 

c) determining appropriate media devices and subdevices required for completion of the task by searching 
10 the control modules (56); and 

d) completing the task by instructing appropriate control modules (56) to provide instructions to the appropriate 
devices and subdevices. 

2. The method as claimed in claim 1 , further comprising the steps of: 

15 

a) determining if the appropriate devices and sub-devices are currently available for completion of the task; and 

b) forming virtual devices from available subdevices of the devices within the network for completion of the 
task when the appropriate devices and subdevices are not currently available. 

20 3. The method as claimed in claim 2, further comprising the step of controlling data flow between the appropriate 
devices and subdevices. 

4. The method as claimed in claim 3, further comprising the steps of: 

25 a) obtaining a topology map of the devices within the network; and 

b) determining a best route for the data flow by analyzing the topology map. 

5. The method as claimed in claim 4, further comprising the steps of: 

30 a) determining if conversion of data flowing between the appropriate devices and subdevices is necessary; and 

b) converting the data flowing between the appropriate devices and subdevices into a proper format if data 
conversion is necessary. 

6. The method as claimed in claim 5, wherein the network is an IEEE 1394 serial bus network. 

35 

7. An apparatus for controlling operation of and communication between a network of devices: 

a) a plurality of control modules (56), each representing a device in the network, wherein each control module 
(56) includes capabilities of a corresponding device and any subdevices within the corresponding device and 

40 further wherein the control module (56) is responsible for control of the device; 

b) an interface (30) for communicating with a user, wherein a task to be completed is requested by the user 
through the interface (30); and 

c) a control circuit (22) coupled to the plurality of control modules (56), to the network and to the interface (30) 
for communicating with a user, for determining appropriate media devices and subdevices required for com- 

45 pletion of the task by searching the control modules (56) and completing the task by instructing appropriate 

control modules (56) to provide instructions to the appropriate devices and subdevices. 

8. The apparatus as claimed in claim 7, wherein the control circuit (22) also determines if the appropriate devices 
and subdevices are currently available for completion of the task and forms virtual devices from available subde- 

so vices to complete the task when the appropriate devices and subdevices are not currently available. 

9. The apparatus as claimed in claim 8, wherein the control circuit (22) further controls data flow between the devices 
within the network. 

55 10. The apparatus as claimed in claim 9 f further comprising a bus manager circuit (70) coupled to the control circuit 
(22) for obtaining a topology map of the devices within the network and determining a best route for the data flow 
by analyzing the topology map. 
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11. The apparatus as claimed in claim 10, wherein the control circuit (22) also converts the data flowing between the 
appropriate devices and subdevices into a proper format if data conversion is necessary. 

12. The apparatus as claimed in claim 11, wherein the control circuit (22) implements pre-defined actions allowing 
users to access basic functionality of the devices in the network. 

13. The apparatus as claimed in claim 12, wherein the control circuit (22) also monitors and records user activity and 
creates custom, user-defined actions. 

14. The apparatus as claimed in claim 11, wherein the network is an IEEE 1394 serial bus network. 

15. A method of managing operation of and communication between a network of devices for completing a task com- 
prising the steps of: 

a) determining appropriate devices and subdevices within a device required for completion of the task, wherein 
virtual devices are formed from available subdevices if appropriate devices are not available for completion 
of the task: and 

b) instructing the appropriate devices and subdevices to complete the task. 

16. The method as claimed in claim 15, further comprising the step of: 

maintaining a control module (56) for each device in the network, wherein the control module (56) includes 
the capabilities of the device and any subdevices within the device and further wherein the control module 
(56) is responsible for control of the device. 

17. The method as claimed in claim 16, further comprising the step of controlling data flow between the appropriate 
devices and subdevices. 

18. The method as claimed in claim 17, further comprising the steps of: 

a) obtaining a topology map of the devices within the network and 

b) determining a best route for the data flow by analyzing the topology map. 

19. The method as claimed in claim 18, further comprising the step of converting the data flowing between the appro- 
priate devices and subdevices into a proper format if necessary. 

20. The method as claimed in claim 19, further comprising the step of providing an interface to a user through which 
the task to be completed is requested. 

21 . The method as claimed in claim 20, wherein the control module (56) provides user interface data to an application 
(48) and responds to user events from the application (48). 

22. The method as claimed in claim 21 , wherein the network is an IEEE 1 394 serial bus network. 

23. The method as claimed In claim 21 , wherein the control module (56) resides in a remote device and is downloaded 
to a host device for execution. 

24. The method as claimed in claim 21 , wherein the control module (56) resides in a local device and is executed from 
a native environment within the local device. 

25. The method as claimed in claim 21 , wherein the control module (56) resides in a local device and is uploaded to 
a host device for execution. 

26. An apparatus for controlling operation of and communication between a network of devices comprising: 

a) an interface circuit (26) for communicating with the devices within the network: and 

b) a control circuit (22) coupled to the interface circuit (26) for determining appropriate devices and subdevices 
within a device required for completion of the task and instructing the appropriate devices and subdevices to 
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complete the task, wherein virtual devices are formed from available subdevices if appropriate devices are 
not available for completion of the task. 

27 The apparatus as claimed in claim 26, further comprising a plurality of control modules (56), each representing a 
5 * device in the network, wherein each control module (56) includes capabilities of a corresponding dev.ce and any 

subdevices within the corresponding device and further wherein the control module (56) is responsible for control 
of the device. 

28 The apparatus as claimed in claim 27, further comprising a bus manager circuit (70) coupled to the control circuit 
10 ' (22) and to the interface circuit (26) for obtaining a topology map of the devices within the network and determining 

a best route for data flow between the appropriate devices and subdevices by analyzing the topology map. 

29. The apparatus as claimed in claim 28, wherein the control circuit (22) also converts the data flowing between the 
appropriate devices and subdevices into a proper format if data conversion is necessary. 
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30. The apparatus as claimed in claim 29, wherein the network is an IEEE 1394 serial bus network. 
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